技術問答
技術文章
iT 徵才
Tag
聊天室
2025 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2024 iThome 鐵人賽
DAY
26
0
自我挑戰組
上班辦公室,下班讀書室:RISC-V / ARM64 體系結構編程與實踐
系列 第
26
篇
# [鐵人賽] Day 26 ARM 第 13 章節 GIC-V2 (2)
16th鐵人賽
ycliang
團隊
晶心壯士III: ALcHemist
2024-09-26 22:32:26
383 瀏覽
分享至
今日的行程:
辦公室:10:00 - 19:30
讀書室:21:30 - 22:30
正片開始
GIC-V2
SGI (Software Generated Interrupts): IPI
PPI (Private Peripheral Interrupts): local timer
SPI (Shared Peripheral Interrupts)
中斷流程
GIC 偵測到中斷發生,會將該中斷標記為 pending
GIC 中的 dispatche 略r 會選一個 priority 最高的 pending
interrupt 到 target CPU 的 CPU interface (也是由 dispatcher 決定)
CPU interface 會決定這個 interrupt 是否可以送給 CPU (CPU 需要處在特定狀態),可以的話,送一個 interrupt 給 target CPU
target CPU 進入 interrupt handling 過程,讀取 GICC_IAR (Interrupt Acknowledge Register) 來 claim 這個 interrupt 並且得到 interrupt ID (或是 CPU ID,如果是 SGI 的話)
當 GIC 偵測到 GICC_IAR 被讀取後,如果 interrupt 是 pending 的話,會變成 active
處理完 interrupt 後,會回傳 EOI (End Of Interrupt) 給 GIC
GIC 有支援 preemptive interrupt,不過由於 linux kernel 在執行 interrupt handling 過程中是 interrupt disable 的狀態,所以不會馬上收到。
書中有附上訊號的時序圖~
GIC-V2 register
-- 略 --
結論
drivers/irqchip/irq-gic.c
RISC-V PLIC sample implementation:
drivers/irqchip/irq-sifive-plic.c
RISC-V AIA (Advanced Interrupt Architecture)
drivers/irqchip/irq-riscv-intc.c
APLIC
IMSIC
留言
追蹤
檢舉
上一篇
[鐵人賽] Day 25 ARM 第 13 章節 GIC-V2
下一篇
[鐵人賽] Day 27 RISC-V 第 18 章節 Vector extension
系列文
上班辦公室,下班讀書室:RISC-V / ARM64 體系結構編程與實踐
共
30
篇
目錄
RSS系列文
訂閱系列文
5
人訂閱
26
# [鐵人賽] Day 26 ARM 第 13 章節 GIC-V2 (2)
27
[鐵人賽] Day 27 RISC-V 第 18 章節 Vector extension
28
[鐵人賽] Day 28 RISC-V 第 18 章 Vector Extension (2)
29
[鐵人賽] Day 29 RISC-V 第 18 章 Vector Extension (3)
30
[鐵人賽] Day 30 總結與回顧
完整目錄
熱門推薦
{{ item.subject }}
{{ item.channelVendor }}
|
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
902
組
團體組數
37
組
累計文章數
19784
篇
完賽人數
529
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
看更多
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
17th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
linux
windows server
css
react
熱門問題
桌機三更半夜自動開機不知在幹啥?是在下載還是在上傳資料?嚇死寶寶.去查設定我沒有設定在三更半夜更新或是掃毒呀!去查紀錄亦沒有當日凌晨的瀏覽紀錄,這到底是怎麼一回事,要如何查詢?是被安裝了病毒軟體?
碩士學歷能幫助我突破職涯天花板嗎?
維護合約的合理性
如何讓Windows 11 Professional 開啟Synology DS925+網路芳鄰的速度加快?
librenms 25.4.0 重開機都要重新設定
Librenms ssl憑證檢查 通知方式-已解決
Exchange EMS掛掉導致Q信(2016)
如何找到電腦網路行為的觸發原因?
熱門回答
碩士學歷能幫助我突破職涯天花板嗎?
維護合約的合理性
桌機三更半夜自動開機不知在幹啥?是在下載還是在上傳資料?嚇死寶寶.去查設定我沒有設定在三更半夜更新或是掃毒呀!去查紀錄亦沒有當日凌晨的瀏覽紀錄,這到底是怎麼一回事,要如何查詢?是被安裝了病毒軟體?
librenms 25.4.0 重開機都要重新設定
Librenms ssl憑證檢查 通知方式-已解決
熱門文章
資安入門與實務應用介紹 29:智能合約漏洞與加密貨幣詐騙案例分析
資安入門與實務應用介紹 28:APT(高階持續性威脅)攻擊解析與防範方法
C++開啟資料夾及檔案的方法
打造你的第一個 MCP Server:從概念到實作
TrueNAS:從入門到入土心得錄01
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}